le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
↳ QTRS
↳ DependencyPairsProof
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
QUICKSORT1(x) -> LOW2(head1(x), tail1(x))
IF_HIGH3(false, n, add2(m, x)) -> HIGH2(n, x)
QUICKSORT1(x) -> HEAD1(x)
IF_QS4(false, x, n, y) -> APP2(quicksort1(x), add2(n, quicksort1(y)))
QUICKSORT1(x) -> TAIL1(x)
LOW2(n, add2(m, x)) -> LE2(m, n)
QUICKSORT1(x) -> HIGH2(head1(x), tail1(x))
LOW2(n, add2(m, x)) -> IF_LOW3(le2(m, n), n, add2(m, x))
HIGH2(n, add2(m, x)) -> IF_HIGH3(le2(m, n), n, add2(m, x))
IF_QS4(false, x, n, y) -> QUICKSORT1(y)
LE2(s1(x), s1(y)) -> LE2(x, y)
IF_QS4(false, x, n, y) -> QUICKSORT1(x)
HIGH2(n, add2(m, x)) -> LE2(m, n)
QUICKSORT1(x) -> IF_QS4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
IF_LOW3(true, n, add2(m, x)) -> LOW2(n, x)
IF_LOW3(false, n, add2(m, x)) -> LOW2(n, x)
IF_HIGH3(true, n, add2(m, x)) -> HIGH2(n, x)
APP2(add2(n, x), y) -> APP2(x, y)
QUICKSORT1(x) -> ISEMPTY1(x)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
QUICKSORT1(x) -> LOW2(head1(x), tail1(x))
IF_HIGH3(false, n, add2(m, x)) -> HIGH2(n, x)
QUICKSORT1(x) -> HEAD1(x)
IF_QS4(false, x, n, y) -> APP2(quicksort1(x), add2(n, quicksort1(y)))
QUICKSORT1(x) -> TAIL1(x)
LOW2(n, add2(m, x)) -> LE2(m, n)
QUICKSORT1(x) -> HIGH2(head1(x), tail1(x))
LOW2(n, add2(m, x)) -> IF_LOW3(le2(m, n), n, add2(m, x))
HIGH2(n, add2(m, x)) -> IF_HIGH3(le2(m, n), n, add2(m, x))
IF_QS4(false, x, n, y) -> QUICKSORT1(y)
LE2(s1(x), s1(y)) -> LE2(x, y)
IF_QS4(false, x, n, y) -> QUICKSORT1(x)
HIGH2(n, add2(m, x)) -> LE2(m, n)
QUICKSORT1(x) -> IF_QS4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
IF_LOW3(true, n, add2(m, x)) -> LOW2(n, x)
IF_LOW3(false, n, add2(m, x)) -> LOW2(n, x)
IF_HIGH3(true, n, add2(m, x)) -> HIGH2(n, x)
APP2(add2(n, x), y) -> APP2(x, y)
QUICKSORT1(x) -> ISEMPTY1(x)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
↳ QDP
↳ QDP
APP2(add2(n, x), y) -> APP2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP2(add2(n, x), y) -> APP2(x, y)
POL(APP2(x1, x2)) = x1
POL(add2(x1, x2)) = 1 + x2
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
↳ QDP
↳ QDP
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
↳ QDP
LE2(s1(x), s1(y)) -> LE2(x, y)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
LE2(s1(x), s1(y)) -> LE2(x, y)
POL(LE2(x1, x2)) = x1
POL(s1(x1)) = 1 + x1
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
↳ QDP
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
IF_HIGH3(false, n, add2(m, x)) -> HIGH2(n, x)
HIGH2(n, add2(m, x)) -> IF_HIGH3(le2(m, n), n, add2(m, x))
IF_HIGH3(true, n, add2(m, x)) -> HIGH2(n, x)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
IF_HIGH3(false, n, add2(m, x)) -> HIGH2(n, x)
IF_HIGH3(true, n, add2(m, x)) -> HIGH2(n, x)
Used ordering: Polynomial interpretation [21]:
HIGH2(n, add2(m, x)) -> IF_HIGH3(le2(m, n), n, add2(m, x))
POL(0) = 0
POL(HIGH2(x1, x2)) = 1 + x2
POL(IF_HIGH3(x1, x2, x3)) = 1 + x3
POL(add2(x1, x2)) = 1 + x2
POL(false) = 0
POL(le2(x1, x2)) = 0
POL(s1(x1)) = 0
POL(true) = 0
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ DependencyGraphProof
↳ QDP
↳ QDP
HIGH2(n, add2(m, x)) -> IF_HIGH3(le2(m, n), n, add2(m, x))
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
LOW2(n, add2(m, x)) -> IF_LOW3(le2(m, n), n, add2(m, x))
IF_LOW3(true, n, add2(m, x)) -> LOW2(n, x)
IF_LOW3(false, n, add2(m, x)) -> LOW2(n, x)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
LOW2(n, add2(m, x)) -> IF_LOW3(le2(m, n), n, add2(m, x))
Used ordering: Polynomial interpretation [21]:
IF_LOW3(true, n, add2(m, x)) -> LOW2(n, x)
IF_LOW3(false, n, add2(m, x)) -> LOW2(n, x)
POL(0) = 0
POL(IF_LOW3(x1, x2, x3)) = x3
POL(LOW2(x1, x2)) = 1 + x2
POL(add2(x1, x2)) = 1 + x2
POL(false) = 0
POL(le2(x1, x2)) = 0
POL(s1(x1)) = 0
POL(true) = 0
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ DependencyGraphProof
↳ QDP
IF_LOW3(true, n, add2(m, x)) -> LOW2(n, x)
IF_LOW3(false, n, add2(m, x)) -> LOW2(n, x)
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
IF_QS4(false, x, n, y) -> QUICKSORT1(y)
IF_QS4(false, x, n, y) -> QUICKSORT1(x)
QUICKSORT1(x) -> IF_QS4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
le2(0, y) -> true
le2(s1(x), 0) -> false
le2(s1(x), s1(y)) -> le2(x, y)
app2(nil, y) -> y
app2(add2(n, x), y) -> add2(n, app2(x, y))
low2(n, nil) -> nil
low2(n, add2(m, x)) -> if_low3(le2(m, n), n, add2(m, x))
if_low3(true, n, add2(m, x)) -> add2(m, low2(n, x))
if_low3(false, n, add2(m, x)) -> low2(n, x)
high2(n, nil) -> nil
high2(n, add2(m, x)) -> if_high3(le2(m, n), n, add2(m, x))
if_high3(true, n, add2(m, x)) -> high2(n, x)
if_high3(false, n, add2(m, x)) -> add2(m, high2(n, x))
head1(add2(n, x)) -> n
tail1(add2(n, x)) -> x
isempty1(nil) -> true
isempty1(add2(n, x)) -> false
quicksort1(x) -> if_qs4(isempty1(x), low2(head1(x), tail1(x)), head1(x), high2(head1(x), tail1(x)))
if_qs4(true, x, n, y) -> nil
if_qs4(false, x, n, y) -> app2(quicksort1(x), add2(n, quicksort1(y)))